package product.service;

import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import product.domain.Attr;
import com.baomidou.mybatisplus.extension.service.IService;
import product.domain.ProductAttrValue;
import product.vo.AttrRespVo;
import product.vo.AttrVo;

import java.util.List;
import java.util.Map;

/**
 * @author panghu
 * @description 针对表【pms_attr(商品属性)】的数据库操作Service
 * @createDate 2023-03-04 21:03:08
 */
public interface AttrService extends CommonService<Attr> {


    /**
     * 查询分页数据
     *
     * @param params
     * @return
     */
    Page<AttrRespVo> queryPageWithAttrRespVo(Map<String, Object> params, Long catId);

    /**
     * 保存属性
     *
     * @param attrVo
     * @return
     */
    boolean saveAttr(AttrVo attrVo);

    /**
     * 根据attrId查询转换成attrVo
     *
     * @param attrId
     * @return
     */
    AttrRespVo getAttrVoById(Long attrId);

    /**
     * 更新属性并更新其相关联的数据
     *
     * @param attrVo
     * @return
     */
    boolean updateWithRelationById(AttrVo attrVo);

    /**
     * 批量删除属性
     *
     * @param ids
     * @return
     */
    boolean removeBatchAttrByIds(List<Long> ids);

    /**
     * 获取当前分组没有关联的所有属性
     *
     * @param params
     * @param attrGroupId
     * @return
     */
    Page<Attr> getNoRelationAttr(Map<String, Object> params, Long attrGroupId);

    List<Attr> getRelationAttr(Long attrgroupId);

    /**
     * 根据分类id查找属性列表
     *
     * @param catId 分类id
     * @return 属性列表
     */
    List<Attr> getListByCatId(Long catId);
}
